package com.cyzy.homework.repository;

import com.cyzy.homework.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Optional;

/**
 * 用户数据访问层
 */
@Repository
public interface UserRepository extends JpaRepository<User, Integer> {
    
    /**
     * 根据用户名查找用户
     */
    Optional<User> findByUsername(Integer username);
    
    /**
     * 根据手机号查找用户
     */
    Optional<User> findByPhone(String phone);
    
    /**
     * 根据角色查找用户列表
     */
    List<User> findByRole(Integer role);
    
    /**
     * 根据班级ID查找学生列表
     */
    @Query("SELECT u FROM User u WHERE u.classId = :classId AND u.role = 0")
    List<User> findStudentsByClassId(@Param("classId") Integer classId);
    
    /**
     * 根据角色和班级ID查找用户列表
     */
    List<User> findByRoleAndClassId(Integer role, Integer classId);
    
    /**
     * 检查用户名是否存在
     */
    boolean existsByUsername(Integer username);
    
    /**
     * 检查手机号是否存在
     */
    boolean existsByPhone(String phone);
    
    /**
     * 查找所有教师
     */
    @Query("SELECT u FROM User u WHERE u.role = 1")
    List<User> findAllTeachers();
    
    /**
     * 查找所有学生
     */
    @Query("SELECT u FROM User u WHERE u.role = 0")
    List<User> findAllStudents();
}





